工控網(wǎng)首頁(yè)
>

應(yīng)用設(shè)計(jì)

>

基于AT91RM9200的嵌入式網(wǎng)絡(luò)攝像機(jī)設(shè)計(jì)

基于AT91RM9200的嵌入式網(wǎng)絡(luò)攝像機(jī)設(shè)計(jì)

2014/1/24 10:26:42

摘要: 本文介紹了一種基于AT91RM9200的嵌入式網(wǎng)絡(luò)攝像機(jī)設(shè)計(jì)方案。該系統(tǒng)以嵌入式Linux 作為操作系統(tǒng), 采用MPEG-4 的專用編碼芯片對(duì)采集到的數(shù)字視頻進(jìn)行壓縮編碼, 生成MPEG- 4 碼流。MPEG- 4 碼流經(jīng)過AT91RM9200 控制器外接的網(wǎng)絡(luò)芯片被輸送到PC 機(jī)。PC 機(jī)端通過內(nèi)嵌MPEG- 4 解壓插件的IE 瀏覽器來播放視頻和控制網(wǎng)絡(luò)攝像機(jī)的狀態(tài)變化。

  關(guān)鍵詞:嵌入式系統(tǒng)AT91RM9200;MPG440公共網(wǎng)關(guān)接口

  引言

  隨著通信技術(shù)和網(wǎng)絡(luò)技術(shù)的迅猛發(fā)展, 通過網(wǎng)絡(luò)遠(yuǎn)程實(shí)時(shí)監(jiān)控重要場(chǎng)所已倍受人們關(guān)注, 網(wǎng)絡(luò)攝像機(jī)在此背景下產(chǎn)生, 并成為人們關(guān)注的焦點(diǎn)。網(wǎng)絡(luò)攝像機(jī)要將高清晰度的實(shí)時(shí)視頻信息通過互聯(lián)網(wǎng)傳送到監(jiān)控終端, 因其信息量巨大, 所以必須壓縮。通常人們采用DSP 與MPEG- 4 算法相結(jié)合的方案來實(shí)現(xiàn), 不僅編程工作量大, 而且產(chǎn)品的成本高。本文所介紹的網(wǎng)絡(luò)攝像機(jī)采用專用的MPEG- 4 壓縮芯片、以嵌入式Linux 作為操作系統(tǒng), 不僅開發(fā)便捷、成本低廉, 而且實(shí)時(shí)性好, 適用范圍廣。

  系統(tǒng)總體設(shè)計(jì)

  系統(tǒng)總體設(shè)計(jì)包括硬件設(shè)計(jì)和軟件設(shè)計(jì)兩部分。硬件設(shè)計(jì)模塊主要包括微控制器模塊、壓縮編碼模塊、網(wǎng)絡(luò)接口模塊和相機(jī)控制模塊四部分。微控制器模塊主要由主控芯片、DataFlash 和SDRAM(1)組成。其中, 主控芯片是整個(gè)控制系統(tǒng)的核心, 它負(fù)責(zé)整個(gè)系統(tǒng)的調(diào)度工作。DataFlash 里固化了嵌入式Linux 內(nèi)核、及其文件系統(tǒng)、應(yīng)用軟件和系統(tǒng)配置文件。SDRAM(1)作為內(nèi)存供系統(tǒng)運(yùn)行使用。壓縮編碼模塊由視頻數(shù)據(jù)采集芯片、MPEG- 4 壓縮編碼芯片、SDRAM(2)組成,負(fù)責(zé)將視頻流轉(zhuǎn)化為MPEG- 4 碼流。網(wǎng)絡(luò)接口模塊主要是配合主控芯片傳送MPEG- 4 碼流。相機(jī)的控制模塊主要由串口芯片組成, 其完成轉(zhuǎn)發(fā)控制相機(jī)命令的功能。當(dāng)系統(tǒng)啟動(dòng)時(shí), 微控制器通SPI( Serial PeripheralInterface, 串行外設(shè)接口) 將Linux 內(nèi)核轉(zhuǎn)入SDRAM( 1) 中, 系統(tǒng)從SDRAM( 1) 中啟動(dòng)。系統(tǒng)啟動(dòng)后, 微控制器通過HPI(Host Peripherial Interface, 主機(jī)接口)控制MPEG- 4 編碼模塊。統(tǒng)結(jié)構(gòu)如圖1 所示。

  

  軟件設(shè)計(jì)部分主要包括嵌入式Linux 移植、MPEG- 4 壓縮編碼模塊、CGI 控制程序和MPEG- 4 解碼程序四部分。嵌入式Linux 系統(tǒng)存放到由AT91RM9200 控制的DataFlash 里,它負(fù)責(zé)整個(gè)系統(tǒng)軟件的調(diào)度工作。MPEG- 4 壓縮編碼模塊主要負(fù)責(zé)模擬視頻流的采集, 并將數(shù)字視頻流壓縮為MPEG- 4 數(shù)據(jù)流。CGI 控制程序主要負(fù)責(zé)對(duì)攝像機(jī)的控制和對(duì)MPEG- 4 視頻流的相關(guān)設(shè)置。MPEG- 4 解碼程序主要負(fù)責(zé)對(duì)通過網(wǎng)絡(luò)得到的MPEG- 4 數(shù)據(jù)流的解碼工作。

  硬件設(shè)計(jì)

  微控制器模塊

  微控制器是本系統(tǒng)的核心部件, 選用的是ATMEL公司的AT91RM9200。它是一款基于ARM920T 核的32位微控制器。其主頻為180MHz, 處理速度快, 功能強(qiáng), 性價(jià)比高, 能很好滿足嵌入式Linux 系統(tǒng)的需求。它在系統(tǒng)中的主要作用是在系統(tǒng)上電時(shí)配置其他芯片的功能寄存器, 在正常工作狀態(tài)下調(diào)度控制整個(gè)系統(tǒng)工作, 通過片內(nèi)以太網(wǎng)控制器控制物理層芯片發(fā)送碼流。

  AT91RM9200 通過片內(nèi)的SPI 總線和SDRAM控制器實(shí)現(xiàn)對(duì)外圍DataFlash 和SDRAM的控制, 利用片內(nèi)的USART 實(shí)現(xiàn)對(duì)串口芯片的控制, 通過片內(nèi)的以太網(wǎng)控制器對(duì)片外網(wǎng)絡(luò)芯片進(jìn)行控制。其控制原理圖如圖2 所示。

  

  壓縮編碼模塊

  壓縮編碼模塊包括模擬視頻采集模塊和MPEG- 4壓縮模塊。視頻采集芯片采用TI 公司的TVP5150, 數(shù)據(jù)壓縮芯片采用映佳公司的MPG440。TVP5150 輸入端可是兩種混合視頻信號(hào)也可是S- Video 端子的視頻信號(hào), 支持NTSC、PAL、SECAM等3 種制式, 其輸出的數(shù)據(jù)色彩格式可以為8bit 4: 2: 2 數(shù)字信號(hào)或者8bit 同步ITU- R BT.656 數(shù)字信號(hào)。MPG440 芯片具有符合工業(yè)標(biāo)準(zhǔn)的16b/32b 的雙向主機(jī)接口, 分別用來與視頻采集芯片和微控制器芯片通信。同時(shí), 具有移動(dòng)偵測(cè)、防偽水印、動(dòng)態(tài)調(diào)整IP 畫格比率、動(dòng)態(tài)調(diào)整圖像質(zhì)量等特性, 支持D1、VGA、CIF、QVGA、QCI 等五種分辨率模式。微控制器通過主機(jī)接口實(shí)現(xiàn)MPG440 的初始配置, 也由此接收MPEG- 4 碼流。壓縮編碼模塊的硬件設(shè)計(jì)原理如圖3 所示。

  

  TVP5150 的AI 模擬輸入口與模擬攝像頭輸出端連接, 向視頻處理芯片傳送模擬視頻信號(hào)。模擬信號(hào)經(jīng)過采樣處理之后通過YOUT0~YOUT7 引腳送到MPG440, 采樣數(shù)據(jù)在PCLK 的上升沿有效, MPG440的VIDEO_CLK 在收到PCLK 的上升沿時(shí)獲得YOUT的信號(hào)。TVP5150 分場(chǎng)同步脈沖和行同步脈沖, 分別對(duì)應(yīng)其輸出端VSYNC、HSYNC。MPG440 正是根據(jù)與之相連的VSYNC 和HSYNC 信號(hào)線來實(shí)現(xiàn)圖像的場(chǎng)同步和行同步操作。MPG440 的視頻輸入數(shù)據(jù)線DATA_TV0 ~DATA_TV7 與TVP5150 的YOUT0 ~YOUT7 相連。MPG440 在接收數(shù)據(jù)的同時(shí), 將其得到的數(shù)據(jù)流傳送給MPEG- 4 壓縮編碼單元, 編碼后的MPEG- 4 數(shù)據(jù)流暫存到SDRAM(2)中。MPG440 片內(nèi)PDMA 控制器根據(jù)配置寄存器的設(shè)置準(zhǔn)確發(fā)起對(duì)SDRAM(2)訪問, 同時(shí)將得到的數(shù)據(jù)流輸送往HPI(主機(jī)總線接口,Host Peripherial Interface) , 以等待AT91RM9200 通過DMA 通道將數(shù)據(jù)發(fā)送到網(wǎng)絡(luò)。

  MPG440 通過HPI 與AT91RM9200 通信,AT91RM9200 將MPG440 的寄存器、存儲(chǔ)空間等資源作為其本身內(nèi)存尋址訪問。MPG440 由AT91RM9200選通線NCS4 來選通, 其在AT91RM9200 尋址空間中的地址段為0X50000000 到0X5FFFFFFF。通過對(duì)MPG440 一系列寄存器的設(shè)置, 可以訪問MPG440 系統(tǒng)存儲(chǔ)空間。MPG440 中斷信號(hào)RSC_INT0 從通用I/O引腳的PB29 輸入, 當(dāng)緩沖器填滿時(shí), RSC_INT0 引腳置低提示AT91RM9200 通過DMA 通道提取MPEG- 4數(shù)據(jù)流。編碼后視頻數(shù)據(jù)讀取過程和MPG440 與主機(jī)通信過程由AT91RM9200 讀信號(hào)CFRD 和寫信號(hào)CFWE 控制。  網(wǎng)絡(luò)模塊

  網(wǎng)絡(luò)模塊硬件設(shè)計(jì)原理如圖4 所示。

  

  AT91RM9200 的在片以太網(wǎng)卡端口和網(wǎng)絡(luò)物理層芯片DM9161E 的MII 接口通信。發(fā)送數(shù)據(jù)時(shí), 首先置發(fā)送使能信號(hào)ETXEN 有效。數(shù)據(jù)發(fā)送端ETX0~ETX1與DM9161 的ETXO~ETX1 引腳對(duì)應(yīng)連接, 作為數(shù)據(jù)發(fā)送通道, 以DM9161E 的時(shí)鐘信號(hào)REF_CLK 發(fā)送數(shù)據(jù)。數(shù)據(jù)接收端ERX 0~ERX1 與DM9161E 的RXDO~RXD1 引腳對(duì)應(yīng)連接, 作為數(shù)據(jù)接收通道。管理時(shí)鐘信號(hào)EMDC 和管理數(shù)據(jù)輸入輸出信號(hào)EMDIO 用來芯片控制參數(shù)的寫入和讀取。DM9161E 的MDINTR 端用來產(chǎn)生中斷信號(hào)。

  片內(nèi)以太網(wǎng)卡通過DMA 通道進(jìn)行數(shù)據(jù)的發(fā)送,不影響AT91RM9200 的正常運(yùn)行。首先正確設(shè)置傳送控制寄存器和傳送地址寄存器的傳送數(shù)據(jù)塊字節(jié)數(shù)、數(shù)據(jù)塊存儲(chǔ)首地址等參數(shù), 隨后依次從指定數(shù)據(jù)存儲(chǔ)區(qū)地址讀取1024b 數(shù)據(jù), 送入內(nèi)部發(fā)送緩沖器中, 由MAC 對(duì)數(shù)據(jù)進(jìn)行封裝發(fā)送, 同時(shí)記錄已傳送字節(jié)數(shù),直到數(shù)據(jù)塊發(fā)送完畢。當(dāng)發(fā)送完一組數(shù)據(jù)后, 發(fā)出DMA中斷請(qǐng)求, 由AT91RM9200 進(jìn)行相應(yīng)的處理。整個(gè)網(wǎng)絡(luò)子系統(tǒng)電路由AT91RM9200 控制和調(diào)度。

  軟件設(shè)計(jì)

  嵌入式Linux 系統(tǒng)主要由四個(gè)部分組成: 引導(dǎo)內(nèi)核啟動(dòng)的文件( bootloader) 、Linux 內(nèi)核文件( kernel) 、虛擬磁盤文件( ramdisk) 、用戶空間文件( user) 。它們分別被放在DataFlash 內(nèi)的四個(gè)分區(qū)模塊中。根據(jù)不同模塊的具體功能采用不同的文件系統(tǒng): bootloader、kernel、ramdisk, 移植完成后不需要?jiǎng)討B(tài)改變, 使用較節(jié)省空間的ROMFS 只讀文件系統(tǒng)user 模塊內(nèi)放置一些可以動(dòng)態(tài)更新的配置文件等, 需要進(jìn)行較多的讀寫操作, 所以使用支持動(dòng)態(tài)擦寫保存的JFFS2 文件系統(tǒng)。

  Linux 移植技術(shù)已經(jīng)成熟, 本文不作詳細(xì)的闡述。下文主要介紹MPEG- 4 壓縮編碼模塊和CGI 模塊的程序設(shè)計(jì)。

  MPEG- 4 壓縮編碼模塊程序設(shè)計(jì)

  該模塊主要完成MPG440 和TI5150 相關(guān)寄存器的配置, 并保證MPEG- 4 碼流的正常輸出。當(dāng)嵌入式Linux系統(tǒng)啟動(dòng)后,首先配置MPG440 的相關(guān)寄存器, 其初始化完成后, 通過I2C總線對(duì)TVP5150 進(jìn)行初始化配置。當(dāng)系統(tǒng)開始?jí)嚎s編碼時(shí),MPEG- 4 碼流接收存儲(chǔ)程序由MPEG- 440 的數(shù)據(jù)流緩沖器標(biāo)志信號(hào)控制。當(dāng)1024b 緩沖器滿時(shí), RISC_INT0 置于低電平, 微控制器通過DMA通道從MPG440 的HPI 口將碼流送到PC 機(jī)端。MPEG-4 壓縮編碼模塊程序流程如圖4 所示。

CGI 程序模塊設(shè)計(jì)

  CGI(Common Gateway Interface) 是外部擴(kuò)展應(yīng)用程序與WWW 服務(wù)器交互的一個(gè)標(biāo)準(zhǔn)接口。本系統(tǒng)CGI 的工作過程: 在PC 機(jī)端的IE 瀏覽器中輸入網(wǎng)絡(luò)攝像機(jī)IP 地址, 嵌入式網(wǎng)絡(luò)服務(wù)器根據(jù)請(qǐng)求, 將相應(yīng)的控制頁(yè)面反饋給IE 瀏覽器, 用戶填寫表單, 然后提交, CGI 程序提取表單的信息, 根據(jù)不同信息來分別處理相應(yīng)的事件, 如調(diào)節(jié)MPEG- 4 相關(guān)屬性、相機(jī)的相關(guān)操作等。CGI 控制原理如圖5 所示。

  CGI 模塊的設(shè)計(jì)主要包括三部分: 嵌入式web 服務(wù)器的配置、html 頁(yè)面的編寫、CGI 程序的設(shè)計(jì)。

  

  嵌入式web 服務(wù)器采用的是Apache, 其配置是以配置文件的形式提供, 放在Ramdisk 中/etc/httpd/conf/目錄下。其配置主要涉及以下三個(gè)方面:

 ?、倥渲酶募穆窂?“DocumentRoot /home/httpd/html”, html 頁(yè)面必須放到此目錄下。

 ?、谂渲肅GI 外部程序所放的路徑:“ScriptAlias /cgi- bin/ home/httpd/cgi- bin/”。

 ?、叟渲铆h(huán)境變量:“SetEenv D_LIBRARY_PATH=/lib:/usr/local/lib:/usr/lib”, 該變量將會(huì)被傳送到CGI 腳本和SSI 頁(yè)面, 以保證CGI 程序能正確找到所依賴的庫(kù)。

  網(wǎng)頁(yè)編寫采用html 與shtml 相結(jié)合的方式。html 的解析速度較快, shtml 可以在普通網(wǎng)頁(yè)中嵌入外部CGI程序, 通過這種方式將系統(tǒng)的默認(rèn)配置反饋給客戶端。

  CGI 程序采用的是C 語言和shell 腳本相結(jié)合的方式, 具體編寫過程, 與通常的了Linux 下編程相同。限于篇幅, 不再贅述。

  MPEG- 4 解碼程序

  映佳科技已提供供二次開發(fā)的MPEG- 4 解碼插件OCX, OCX 在PC 機(jī)端注冊(cè)后, OCX 函數(shù)可方便地被網(wǎng)頁(yè)調(diào)用, 從而實(shí)現(xiàn)在PC 機(jī)端觀看實(shí)時(shí)圖像。

  總結(jié)

  本文介紹了一種利用AT91RM9200、TVP5150,MPG440 和DM9161E 等芯片設(shè)計(jì)的嵌入式網(wǎng)絡(luò)攝像機(jī)。經(jīng)測(cè)試, 該系統(tǒng)穩(wěn)定、可靠、實(shí)時(shí)性好、圖像質(zhì)量出色。該產(chǎn)品可廣泛應(yīng)用于交通監(jiān)控和工業(yè)監(jiān)控以及家庭監(jiān)控、視頻會(huì)議話等眾多領(lǐng)域。

投訴建議

提交

查看更多評(píng)論
其他資訊

查看更多

超越傳統(tǒng)直覺,MATLAB/Simulink助力重型機(jī)械的智能化轉(zhuǎn)型

新大陸自動(dòng)識(shí)別精彩亮相2024華南國(guó)際工業(yè)博覽會(huì)

派拓網(wǎng)絡(luò)被Forrester評(píng)為XDR領(lǐng)域領(lǐng)導(dǎo)者

智能工控,存儲(chǔ)強(qiáng)基 | ??低晭砭手黝}演講

展會(huì)|Lubeworks路博流體供料系統(tǒng)精彩亮相AMTS展會(huì)